package com.zyh.scs.admin.service;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.IService;
import com.zyh.scs.admin.api.dto.RechargeBatchJsonDTO;
import com.zyh.scs.admin.api.dto.RechargePageDTO;
import com.zyh.scs.admin.api.dto.RechargePhoneDTO;
import com.zyh.scs.admin.api.entity.SysUser;
import com.zyh.scs.admin.api.entity.UserRecharge;
import com.zyh.scs.admin.api.vo.ReadExcelVO;
import com.zyh.scs.admin.api.vo.UserHistoryExcelVO;
import org.springframework.web.multipart.MultipartFile;

import java.util.List;

/**
 * 用户充值
 *
 * @author hwh
 */
public interface UserRechargeService extends IService<UserRecharge> {

    /**
     * 分页查询用户充值列表
     *
     * @param page        分页对象
     * @return
     */
    IPage getUserPage(Page page);


    /**
     * 通过用户id,手机号,工号查询用户
     *
     * @param param 参数
     * @return
     */
    List<SysUser> getRechargePhone(String param);


    /**
     * 单个充值
     *
     * @param rechargePhoneDTO 参数对象
     * @return
     */
    Boolean recharge(RechargePhoneDTO rechargePhoneDTO);


    /**
     * 批量充值解析文件
     *
     * @param multipartFile excel文件对象
     * @return
     */
    ReadExcelVO read(MultipartFile multipartFile);

    /**
     * 批量充值
     *
     * @param rechargeBatchJsonList 参数对象
     * @return
     */
    boolean rechargeBatch(RechargeBatchJsonDTO rechargeBatchJsonList);

    /**
     * 批量充值 通过id 和文件
     *
     * @param multipartFile 参数对象
     * @param historyId
     * @return
     */
    boolean getIdFile(MultipartFile multipartFile, Long historyId,String fileName);


    /**
     * 分页查询用户充值记录列表
     *
     * @param page        分页对象
     * @return
     */
    IPage getUserRecordPage(Page page, RechargePageDTO rechargePageDTO);

    /**
     * 充值记录流水导出Excel
     *
     * @param rechargePageDTO  参数
     * @return
     */
    List<UserHistoryExcelVO> getUserRecordExport(RechargePageDTO rechargePageDTO);

    /**
     * 导出表头
     */
    String getExcel();

}
